import React from 'react';
import { StackActions, useNavigation } from '@react-navigation/native';
import { type StyleProp, type ViewStyle } from 'react-native';

import I18n from '../../../../i18n';
import { isIOS } from '../../../../lib/methods/helpers/deviceInfo';
import Container from './HeaderButtonContainer';
import Item, { type IHeaderButtonItem } from './HeaderButtonItem';
import { useTheme } from '../../../../theme';

interface IHeaderButtonCommon extends IHeaderButtonItem {
	navigation?: any; // TODO: Evaluate proper type
	style?: StyleProp<ViewStyle>;
}

// Left
export const Drawer = ({
	navigation,
	testID,
	style = {},
	onPress = () => navigation?.toggleDrawer(),
	...props
}: IHeaderButtonCommon) => {
	const { colors } = useTheme();
	return (
		<Container style={style} left>
			<Item
				accessibilityLabel={I18n.t('Menu')}
				iconName='hamburguer'
				onPress={onPress}
				testID={testID}
				color={colors.fontDefault}
				{...props}
			/>
		</Container>
	);
};

export const CloseModal = React.memo(({ testID, onPress, ...props }: IHeaderButtonCommon) => {
	const { dispatch } = useNavigation();
	return (
		<Container left>
			<Item
				accessibilityLabel={I18n.t('Close')}
				iconName='close'
				onPress={arg => {
					if (onPress) return onPress(arg);
					dispatch(StackActions.pop());
				}}
				testID={testID}
				{...props}
			/>
		</Container>
	);
});

export const CancelModal = React.memo(({ onPress, testID, ...props }: IHeaderButtonCommon) => (
	<Container left>
		{isIOS ? (
			<Item title={I18n.t('Cancel')} onPress={onPress} testID={testID} {...props} />
		) : (
			<Item iconName='close' onPress={onPress} testID={testID} {...props} />
		)}
	</Container>
));

// Right
export const More = React.memo(({ onPress, testID, ...props }: IHeaderButtonCommon) => (
	<Container>
		<Item iconName='kebab' onPress={onPress} testID={testID} {...props} />
	</Container>
));

export const Download = React.memo(({ onPress, testID, ...props }: IHeaderButtonCommon) => (
	<Container>
		<Item iconName='download' onPress={onPress} testID={testID} {...props} />
	</Container>
));

export const Preferences = React.memo(({ onPress, testID, ...props }: IHeaderButtonCommon) => (
	<Container>
		<Item iconName='settings' onPress={onPress} testID={testID} {...props} />
	</Container>
));

export const Legal = React.memo(
	({ navigation, testID, onPress = () => navigation?.navigate('LegalView'), ...props }: IHeaderButtonCommon) => (
		<More accessibilityLabel={I18n.t('More')} onPress={onPress} testID={testID} {...props} />
	)
);
